<script setup>
import { onMounted, ref } from "vue";
import luckysheet from "luckysheet";
import LuckyExcel from "luckyexcel";
// import index from "@/components/analysisSheetComponents/soil/tmpl85/index.vue";
import { useAnalysetStore } from "@/store/index";
import AnalyesAPI from "@/api/system/analyes";
import {
  processTableData,
  filterValidSampleAdatas,
  splitDataIntoPages,
} from "@/utils/method";
import Device1 from "@/components/analysisSheetComponents/component/Device1.vue";
import Index from "@/components/analysisSheetComponents/component/index.vue";
let options = {
  container: "luckysheet", //luckysheet为容器id
  lang: "zh",
  autoCalculate: true,
  data: [
    {
      column: 6, // 列数
      row: 10, // 列数
      defaultRowHeight: 30, // 自定义行高
      defaultColWidth: 100, // 自定义列宽
      celldata: [
        // 初始化表格数据，第一行包含表头
        { r: 0, c: 0, v: "待测物" }, // A1
        { r: 0, c: 1, v: "类型" }, // A1
        { r: 0, c: 2, v: "检出限(μg/kg)" },
        { r: 0, c: 3, v: "溶液浓度ρex(μg/L)" },
        { r: 0, c: 4, v: "样品含量ω(μg/kg)" },
        { r: 0, c: 5, v: "测定结果" },
        { r: 0, c: 6, v: "备注" },
      ], // 初始化数据
      config: {
        merge: {}, // 合并单元格
        rowlen: {}, // 表格行高
        columnlen: {
          // 设置列宽
          0: 200,
          1: 150,
          2: 150,
          3: 150,
          4: 150,
          5: 150,
          6: 150,
          7: 150,
          8: 150,
          9: 150,
          10: 150,
          11: 150,
        }, // 表格列宽
      },
    },
  ],
  showinfobar: false, // 隐藏信息栏
  showtoolbar: true, // 隐藏工具栏
};
const tableOption = ref([{ table: "仪器名称", id: 1 }]);
const sheetData = ref("");
const waterForm = ref({
  bdatas: {
    dcwName: [], //待测物名称
    jcx: [], //检出限
    jbhsycd: {
      jbqsyhl: {
        ypbh1: "",
        ypbh2: "",
        ypbh3: "",
        ypbh4: "",
        ypbh5: "",
        ypbh6: "",
      },
      bzypcdnd: { bzypcdnd1: "", bzypcdnd2: "", bzypcdnd3: "" },
      sfhg: { sfhg1: "", sfhg2: "", sfhg3: "" },
      hsl: { hsl1: "", hsl2: "", hsl3: "" },
    },
    rypz: Array.from({ length: 7 }, () => ({
      ry_bzxbybh: "",
      ry_bzzbynd: "",
      ry_zbyyxrq: "",
      ry_yqzbytj: "",
      ry_drtj: "",
      ry_zjynd: "",
      ry_yqzjytj: "",
      ry_drtj2: "",
      ry_syynd: "",
    })),
    jzqxpz: Array.from({ length: 7 }, () => ({
      jz_dcwsyyjrl: "",
      jz_tdwsyyjrl: "",
      jz_nbsyyjrl: "",
      jz_drtj: "",
      jz_qxnd: "",
    })),
    pxycd_fx: {},
    jbycd: {},
  },
  pxycd: [],
  cdtj: {},
  device: {
    device_name: [],
    device_model: [],
    device_number: [],
  },
});
const switchAB = ref(true);
const checkTime = ref("");
const processedData = ref([]);
const cdatas = ref([]);
const checkDialogVisible = ref(false);
const analyseStatusPage = useAnalysetStore();
const record_sn = analyseStatusPage.waterForm.record_sn;
// pdf显示隐藏
const showTargetPage = ref(false);
const tableHeaders = ref([]);
const tabler = ref([]);
const switchAdd = ref(true);
// 在组件挂载后初始化 Lucky-sheet
onMounted(() => {
  // 初始化表格
  luckysheet.create(options);
  // 获取表单信息
  getWaterCapacity();
  getMethod();
});

// 获取信息( 复制粘贴)
const getMethod = () => {
  waterForm.value.task_name = analyseStatusPage.waterForm.task_number; //任务名称
  // waterForm.value.method = analyseStatusPage.waterForm.tableItem.test_method
  //   ? analyseStatusPage.waterForm.tableItem.test_method
  //   : analyseStatusPage.waterForm.tableItem.test_method_number; //分析方法
  // waterForm.value.category_id =
  //   analyseStatusPage.waterForm.tableItem.sample_category; // 样品类别

  checkTime.value = analyseStatusPage.waterForm.tableItemList.submit_dates;
};
// 用于获取最新的表格数据
const getUpdatedData = () => {
  checkDialogVisible.value = true;
};
const handleCheckClose = () => {
  checkDialogVisible.value = false;
};

// 获取——获取 水质容量A   工作表
const getWaterCapacity = () => {
  let josn = {
    add_form_id: analyseStatusPage.waterForm.add_form_id,
    task_id: analyseStatusPage.waterForm.taskId,
    // record_sn: record_sn,
    record_sn: record_sn,
  };
  AnalyesAPI.getAnalyseACapacity(josn).then((data) => {
    if (!Array.isArray(data) || data.length !== 0) {
      waterForm.value = data;
      sheetData.value = data.configs;
      options.data = sheetData.value;
      luckysheet.create(options);
      waterForm.value.bdatas =
        Array.isArray(data.bdatas) && data.bdatas.length === 0
          ? {}
          : data.bdatas;
      processedData.value = data.adatas;
      tableHeaders.value = splitDataIntoPages(data.adatas, 22);

      tabler.value = getHeadersData();
    } else {
      waterForm.value.device = {
        device_name: [],
        device_model: [],
        device_number: [],
      };
    }
  });
};
// 保存新增表单
const handleAddWaterPh = () => {
  sheetData.value = luckysheet.getLuckysheetfile();
  options.data = sheetData.value; // 将字符串解析为 JSON
  console.log(options.data);
  const data = options.data[0].data.map((row) => {
    return row
      .map((cell) => {
        return cell
          ? {
              field: cell.m || "默认字段",
              value: cell.v || null,
            }
          : null;
      })
      .filter((cell) => cell !== null); // 删除 null 值
  });
  processedData.value = filterValidSampleAdatas(processTableData(data));

  //   调保存新增接口
  AnalyesAPI.addWaterCapacity({
    ...waterForm.value,
    // record_sn: record_sn,
    record_sn: 85,
    // id: analyseStatusPage.waterForm.id,
    task_id: analyseStatusPage.waterForm.taskId,
    configs: sheetData.value,
    add_form_id: analyseStatusPage.waterForm.add_form_id,
    adatas: processedData.value,
  }).then((data) => {
    console.log("调接口拿数据", data);
    ElMessage.success("保存成功！");
    // getWaterCapacity();
    switchAdd.value = false;
  });
};

// 确认提交校核
const handleSubmit = () => {
  const formattedDate = checkTime.value
    ? dayjs(checkTime.value).format("YYYY-MM-DD")
    : "";
  console.log(analyseStatusPage.waterForm.id);
  AnalyesAPI.handleCheckTimeData({
    id: analyseStatusPage.waterForm.add_form_id,
    submit_date: formattedDate,
  }).then((data) => {
    if (data === 1) {
      ElMessage.success("提交成功！");
      checkDialogVisible.value = false;
    }
  });
};

// 上传文件
const loadExcel = (evt) => {
  const files = evt.target.files;
  console.log(files);
  if (files == null || files.length == 0) {
    alert("No files wait for import");
    return;
  }
  let name = files[0].name;
  let suffixArr = name.split("."),
    suffix = suffixArr[suffixArr.length - 1];
  if (suffix != "xlsx") {
    alert("Currently only supports the import of xlsx files");
    return;
  }
  LuckyExcel.transformExcelToLucky(
    files[0],
    function (exportJson, luckysheetfile) {
      if (exportJson.sheets == null || exportJson.sheets.length == 0) {
        alert(
          "Failed to read the content of the excel file, currently does not support xls files!"
        );
        return;
      }
      console.log("exportJson", exportJson.sheets);
      jsonData.value = exportJson;

      luckysheet.destroy();
      luckysheet.create({
        container: "luckysheet", //luckysheet is the container id
        showinfobar: false,
        data: exportJson.sheets,
        title: exportJson.info.name,
        userInfo: exportJson.info.name.creator,
      });
    }
  );
};

const handleSwitch = () => {
  switchAB.value = !switchAB.value;
};
// 下载
const downloadDetail = async () => {
  // console.log("下载");
  showTargetPage.value = true;
  await nextTick();
  window.print();
  setTimeout(() => {
    showTargetPage.value = false;
  }, 1000);
};
</script>

<template>
  <div class="card">
    <div v-show="!showTargetPage && switchAB">
      <el-card class="box-card">
        <h1 style="text-align: center">
          土壤 吹扫捕集-气相色谱质谱法分析原始记录（一）（A面）
        </h1>
        <div>SXLPHJ/JL/CX-22-85</div>
        <table class="table">
          <tr style="background-color: #f2f2f2">
            <td colspan="2">任务编号</td>
            <td colspan="4">
              <el-input
                v-model="waterForm.task_name"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              />
            </td>
            <td colspan="1" style="width: 10%">采样日期</td>
            <td colspan="1" style="width: 8%">
              <el-input
                v-model="waterForm.sampling_time"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              />
            </td>
            <td colspan="4">分析日期</td>
            <td colspan="4" style="width: 10%">
              <el-input
                v-model="waterForm.anal_time"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              />
            </td>
            <td colspan="8">环境温度</td>
            <td colspan="3">
              <el-input
                v-model="waterForm.temperature"
                style="width: 100%; border: 1px solid transparent"
              >
                <template #append>
                  <span style="background-color: transparent; color: black">
                    ℃
                  </span>
                </template>
              </el-input>
            </td>
          </tr>
          <tr>
            <Device1 :water-form="waterForm" />
            <td colspan="8">环境湿度</td>
            <td colspan="3">
              <el-input
                v-model="waterForm.humidity"
                style="width: 100%; border: 1px solid transparent"
              >
                <template #append>
                  <span style="background-color: transparent; color: black">
                    %RH
                  </span>
                </template>
              </el-input>
            </td>
          </tr>
          <tr style="background-color: #f2f2f2">
            <td colspan="2">分析方法</td>
            <td colspan="25">
              <el-input
                v-model="waterForm.method"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
          </tr>
          <tr>
            <td colspan="2" rowspan="3">测定条件</td>
            <td colspan="25">
              <el-input
                v-model="waterForm.cdtj.cdtj1"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
          </tr>
          <tr>
            <td colspan="25">
              <el-input
                v-model="waterForm.cdtj.cdtj2"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
          </tr>
          <tr>
            <td colspan="25">
              <el-input
                v-model="waterForm.cdtj.cdtj3"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
          </tr>
          <tr style="background-color: #f2f2f2">
            <td colspan="2">标准使用液浓度</td>
            <td colspan="4">
              <el-input
                v-model="waterForm.bzsyynd"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
            <td colspan="2" style="width: 8%">试料体积</td>
            <td colspan="4">
              <el-input
                v-model="waterForm.sltj"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
            <td colspan="13">计算公式</td>
          </tr>
          <tr>
            <td colspan="2" rowspan="2">替代物</td>
            <td colspan="4" rowspan="2">
              <el-input
                v-model="waterForm.tdw"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
            <td colspan="2" style="width: 8%">替代物浓度</td>
            <td colspan="4">
              <el-input
                v-model="waterForm.tdwnd"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
            <td colspan="2">
              <input type="checkbox" />
              低含量
            </td>
            <td colspan="11">
              <el-input
                v-model="waterForm.dhl"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
          </tr>
          <tr>
            <td colspan="2" style="width: 8%">替代物加入量</td>
            <td colspan="4">
              <el-input
                v-model="waterForm.tdwjrl"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
            <td colspan="2">
              <input type="checkbox" />
              高含量
            </td>
            <td colspan="11">
              <el-input
                v-model="waterForm.ghl"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
          </tr>
          <tr style="background-color: #f2f2f2">
            <td colspan="2">样品编号</td>
            <td colspan="1">
              <el-input
                v-model="waterForm.ypbh"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
            <td colspan="1">样品量m(g)</td>
            <td colspan="1">
              <el-input
                v-model="waterForm.ypl"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
            <td colspan="1" style="width: 8%">干物质wdm(%)</td>
            <td colspan="1" style="width: 8%">
              <el-input
                v-model="waterForm.gwz"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
            <td colspan="1">含水率w(%)</td>
            <td colspan="4" style="width: 10%">
              <el-input
                v-model="waterForm.hsl"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
            <td colspan="1" style="width: 20%">提取液体积Vc(mL)</td>
            <td colspan="8">
              <el-input
                v-model="waterForm.tqytj"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
            <td colspan="1">吹扫提取液体积Vs(mL)</td>
            <td colspan="3">
              <el-input
                v-model="waterForm.cstqytj"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
          </tr>
          <tr>
            <td colspan="2">备注</td>
            <td colspan="24">
              <el-input
                v-model="waterForm.notes"
                style="width: 100%; border: 1px solid transparent"
                placeholder="请输入"
              >
                >
              </el-input>
            </td>
          </tr>
        </table>
        <!--      <input id="uploadBtn" type="file" @change="loadExcel"/>-->
        <div id="luckysheet" style="width: 100%; height: 500px" />
      </el-card>
    </div>
    <div v-show="!switchAB">
      <!-- <index :water-form="waterForm" /> -->
    </div>

    <div v-show="!showTargetPage">
      <Index
        :water-form="waterForm"
        :handle-add-water-ph="handleAddWaterPh"
        :check-time="checkTime"
        :switch="true"
        :switch-a-b="switchAB"
        :handle-switch="handleSwitch"
        :get-water-capacity="getWaterCapacity"
        :switch-add="switchAdd"
      />
    </div>
    <!--    提交校核-->
    <el-dialog
      v-model="checkDialogVisible"
      title="提交校核"
      width="30%"
      center
      :before-close="handleCheckClose"
    >
      <div class="check">
        <!--        头部-->
        <div
          class="check-header"
          style="display: flex; align-items: center; margin-bottom: 20px"
        >
          <p>表单填写日期：</p>
          <el-date-picker
            v-model="checkTime"
            style="border: 1px solid #cccccc; border-radius: 6px; width: 70%"
            type="date"
            placeholder="请选择"
          />
        </div>
        <div class="check-footer">
          <el-button style="width: 48%" @click="handleCheckClose">
            取消
          </el-button>
          <el-button type="primary" style="width: 48%" @click="handleSubmit">
            确认
          </el-button>
        </div>
      </div>
    </el-dialog>
  </div>
</template>

<style scoped>
.card {
  padding: 20px 25px;
}

.table {
  width: 100%;
  border-collapse: collapse; /* 表格边框合并 */
  text-align: left; /* 默认左对齐 */
  font-size: 14px; /* 字体大小 */
  color: #606266; /* 默认字体颜色 */
  margin-bottom: 20px;
}

.table th,
.table td {
  border: 1px solid #c2bfbf; /* 表格单元格边框颜色 */
  padding: 12px; /* 单元格内边距 */
}

.table th {
  background: #f5f7fa; /* 表头背景色 */
  font-weight: 600; /* 表头字体加粗 */
  color: #303133; /* 表头字体颜色 */
  text-align: center; /* 表头居中 */
}

.table td {
  width: 15%;
}

.table-td {
  display: flex;
}

::v-deep .el-input__wrapper {
  background-color: transparent;
  box-shadow: none;
}

::v-deep .el-select__wrapper {
  background-color: transparent;
  box-shadow: none;
}

::v-deep .el-input-group__append {
  background-color: transparent;
  box-shadow: none;
}
</style>
